JavaScript斐波纳契数列非递归算法

一般斐波纳契数列采用递归或是数组缓存的方式,这里的方法不考虑重复计算斐波纳契数列的情况。

 

fibonacci 数列定义,查看百度百科的解释>>

n = 1,2 时,fib(n) = 1 
n > 2 时,fib(n) = fib(n-2) + fib(n-1)

 

1、递归

function Fib(n) { 
    return n < 2 ? n : (Fib(n - 1) + Fib(n - 2)); 
}

2、数组缓存

var IterMemoFib = function() { 
    var cache = [1, 1]; 
    return function (n) { 
        if (n >= cache.length) { 
            for (var i = cache.length; i < n ; i++ ) { 
                cache[i] = cache[i - 2] + cache[i - 1]; 
            } 
        } 
        return cache[n - 1]; 
    } 
}();

3、直接使用加法

function fib(n) { 
    if (n < 2) { 
        return 1; 
    } 
    var a = 1, b = 1; 
    for (var i = 2; i < n - 1 ;i++ ) { 
        b = a + b; 
        a = b - a; 
    } 
    return a + b; 
}

 

对比:

如果只使用一次运算,第三种方法速度最快;

如果多次使用,第二种方法明显优于其它两种;

在n较大的情况下不推荐使用第一种;n为10*10000的时候递归就已经报内存溢出了

 

下面是在IE8下测试的结果(n为100W):

image

 

如果只需要计算一次,第三种方法应该是最优的,而且当n越大的时候,数组占有的内存空间也将越大。

 

完整代码:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
 <head>
  <title> new document </title>
  <meta name="generator" content="editplus" />
  <meta name="author" content="" />
  <meta name="keywords" content="" />
  <meta name="description" content="" />
  <meta http-equiv='content-type' content='text/html;charset=utf-8' />
 </head>

 <body>
  
<script type="text/javascript">
	
function Fib(n) {
	return n < 2 ? n : (Fib(n - 1) + Fib(n - 2));
}

var IterMemoFib = function() {
	var cache = [1, 1];
	return function (n) {
		if (n >= cache.length) {
			for (var i = cache.length; i < n ; i++ ) {
				cache[i] = cache[i - 2] + cache[i - 1];
			}
		}
		return cache[n - 1];
	}
}();

function fib(n) {
	if (n < 2) {
		return 1;
	}
	var a = 1, b = 1;
	for (var i = 2; i < n - 1 ;i++ ) {
		b = a + b;
		a = b - a;
	}
	return a + b;
}

var num = 10000*100;

function test(fn, n) {
	var date = +new Date();	
	fn(n);
	return new Date().getTime() - date;
}

//document.write('第一种方法,运算时间:' + test(Fib, num) + '<br/>');
document.write('第二种方法,运算时间:' + test(IterMemoFib, num) + '<br/>');
document.write('第三种方法,运算时间:' + test(fib, num));

document.write('<br/><br/><br/>');

document.write('第二种方法,运算时间:' + test(IterMemoFib, num) + '<br/>');
document.write('第三种方法,运算时间:' + test(fib, num));
</script>

 </body>
</html>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值